<template>
  <div class="custom-form">
    <el-row :gutter="15">
      <el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="100px"
        :key="showFormKey">
        <!-- 排班申请 -->
        <el-col :span="24">
          <el-form-item label-width="0" prop="field1000e93">
            <h2 align='center' style="color:undefined;font-size: nullpx;text-align: center">排班申请</h2>
          </el-form-item>
        </el-col>
        <!-- 职级 -->
        <el-col :span="24">
          <el-form-item label="职级名称" v-show="false">
            <el-input v-model="formData['F_Job']" placeholder="请输入职级信息"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 申请人id -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('申请人id')">
            <el-input v-model="formData['F_UserId']" placeholder="请输入申请人id"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 申请人姓名 -->
        <el-col :span="24">
          <el-form-item :label="$t('申请人姓名')" >
            <el-input v-model="formData['F_UserName']" placeholder="请输入申请人姓名"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 申请时间 -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('申请时间')">
            <el-input v-model="formData['F_Create_Time']" placeholder="请输入申请时间"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 部门名称 -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('部门名称1')">
            <el-input v-model="formData['F_DepartmentName']" placeholder="请输入部门名称"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 部门id -->
        <el-col :span="24">
          <el-form-item :label="$t('部门名称')" prop="F_DepartmentId">
            <el-select
              v-model="formData['F_DepartmentId']"
              placeholder="请选择部门"
              :style="{ width: '100%' }"
              @change="Handleselect"
            >
            <el-option
              v-for="(item, index) in F_DepartmentData"
              :key="index"
              :label="item.F_FullName"
              :value="item.F_DepartmentId"
            ></el-option>
            </el-select>
          </el-form-item>
        </el-col>
        <!-- 角色id -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('角色id')">
            <el-input v-model="formData['F_RoleId']" placeholder="请输入角色id"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 角色名称 -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('角色名称')">
            <el-input v-model="formData['F_RoleName']" placeholder="请输入角色名称"
              :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 地区 -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('地区')">
            <el-input v-model="formData['F_Area']" placeholder="请输入地区名称"
            :readonly="true"
              :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>

        <!-- 考勤组id -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('考勤组id')" prop="F_AttendanceGroupId">
            <el-input v-model="formData['F_AttendanceGroupId']" placeholder="请输入考勤组id"
              :disabled="hasDisabledPermission('F_AttendanceGroupId',false)"
              :readonly="true" clearable
              :style="{width: '100%'}"></el-input>
          </el-form-item>
        </el-col>
        <!-- 考勤组名称 -->
        <el-col :span="24">
          <el-form-item :label="$t('考勤组名称')" prop="F_AttendanceGroupName">
            <el-input v-model="formData['F_AttendanceGroupName']" placeholder="请输入考勤组名称"
              :disabled="hasDisabledPermission('F_AttendanceGroupName',false)"
              :readonly="true" clearable
              :style="{width: '100%'}"></el-input>
          </el-form-item>
        </el-col>
       
        <!-- 上传附件 -->
        <el-col :span="24" >
          <el-form-item :label="$t('上传附件')" prop="F_FileUrl">
            <xjr-custom-upload :config="F_FileUrlConfig"
              :disabled="hasDisabledPermission('F_FileUrl',false)" v-model="formData['F_FileUrl']"
              list-type="text"></xjr-custom-upload>
          </el-form-item>
        </el-col>
        <!-- 已生效 -->
        <el-col :span="24" v-show="false">
          <el-form-item :label="$t('已生效')" prop="F_IsEffective">
            <el-input v-model="formData['F_IsEffective']" placeholder="请输入已生效"
              :disabled="hasDisabledPermission('F_IsEffective',false)"
              :readonly="!hasEditPermission('F_IsEffective',false)" clearable :style="{width: '100%'}">
            </el-input>
          </el-form-item>
        </el-col>
        <!-- 备注 -->
        <el-col :span="24">
          <el-form-item :label="$t('备注')" prop="F_Remark">
            <el-input v-model="formData['F_Remark']" type="textarea" placeholder="请输入备注"
              :disabled="hasDisabledPermission('F_Remark',false)"
              :readonly="!hasEditPermission('F_Remark',false)" :autosize="{minRows: 4, maxRows: 4}"
              :style="{width: '100%'}"></el-input>
          </el-form-item>
        </el-col>
        <!-- 意见簿 -->
        <el-col :span="24" v-show="optionsFlag">
          <el-form-item :label="$t('意见簿')" prop="field108895f">
            <xjr-opinion-comonent :value="formData.field108895f"></xjr-opinion-comonent>
          </el-form-item>
        </el-col>
        <el-col :span="24" v-if="!isWorkflowForm">
          <el-form-item size="large" v-if="isEdit">
            <el-button type="primary" @click="submitForm" :loading="submitLoading">
              {{submitLoading?$t('workFlow.WFMenu.hintSubmit'):$t('submit')}}</el-button>
            <el-button @click="cancelForm">{{$t('cancelText')}}</el-button>
          </el-form-item>
        </el-col>
      </el-form>
    </el-row>
  </div>
</template>
<script>

  import FilterableDataList from '@/components/generator/clientComponents/FilterableDataList.vue';
  import workflowFormAuthorize from "@/mixins/workflowFormAuthorize";
  import authorizeMixin from "@/mixins/authorize";
  import { baseUrl } from "@/config/env";
  import request from "@/router/axios";
  import {getGroupByUserId,getUserDetailsById} from '@/api/user.js';
  export default {
    mixins: [authorizeMixin,workflowFormAuthorize],
  
  components: {},
  props: ['keyValue', 'isEdit', 'disabled'],
  data() {
    let _this = this
    return {
      submitLoading: false,
      showForm: true,
      showFormKey: 1,
      reRenderSubform: false,
      operationVal: 'add',
      isAdd: true,
      addressUrl:'scheduling_approve',
      mainTableName: 'oa_scheduling_approve',
      formConfig: {},
      formData: {
        'field1000e93': '',
        'F_AttendanceGroupId': '',
        'F_AttendanceGroupName': '',
        'F_FileUrl': null,
        'F_IsEffective': 0,
        'F_Remark': '',
        'field108895f': null,
        'F_Job':'',//职级
        'F_UserId': '',//申请人id
        'F_UserName':'', //申请人姓名
        'F_Create_Time':'',//申请时间
        'F_DepartmentId': '',//部门id
        'F_DepartmentName':'',//部门名称
        'F_RoleId':'',//角色id
        'F_RoleName':'',//角色名称
        'F_Area':'',//地区
      },
      rules: {
        F_DepartmentId:[{
          required: true,
          message: '请选择部门',
          trigger: 'change'
        }],
        F_AttendanceGroupId: [{
          required: true,
          message: '请输入考勤组id',
          trigger: 'blur'
        }],
        F_AttendanceGroupName: [{
          required: true,
          message: '请输入考勤组名称',
          trigger: 'blur'
        }],
        F_FileUrl: [{
          required: true,
          message: '上传附件不能为空',
          trigger: 'change'
        }],
        F_IsEffective: [{
          required: true,
          message: '请输入已生效',
          trigger: 'blur'
        }],
        F_Remark: [],
      },
      F_FileUrlConfig: {
        "showTip": false,
        "fileSize": 2,
        "sizeUnit": "MB",
        "buttonText": "点击上传",
        "disabled": false
      },
      F_DepartmentData:[],
      F_RoleData:[],
    }
  },
  computed: {},
  watch: {},
  async created() {
    this.formConfig = this.getFormConfig();
   
  },
  async mounted() {
    //TODO   再这里做数据回填 请求表单数据
   
    if(this.keyValue){
        this.isAdd = false;
    }
    if(!this.isAdd&&this.keyValue){
      this.operationVal = 'edit';
      try {
        let res = await request({
          url: baseUrl + "/"+this.addressUrl+"/" + this.keyValue,
          method: "get",
      });
      this.formData = res.data.data
          this.showFormKey++;
      } catch (error) {
      }
    }
    this.getGroupByUserId()
    this.getUserInfo()
  },
  methods: {
    getFormData() {
      let key = this.mainTableName + 'Entity';
      let returnParams = {};
      returnParams[key] = this.formData;
      return {
        ...returnParams,
      };
    },
    validateForm() {
      this.$refs['elForm'].validate(valid => {});
    },
    async aysncValidateForm() {
      let validataArry = []
      validataArry.push(new Promise((resolve, reject) => {
        this.$refs['elForm'].validate(valid => {
          resolve(valid)
        })
      }))
      let res = await Promise.all(validataArry)
      if (res.includes(false)) {
        return false
      }
      else {
        return true;
      }
    },
    changeTableData() {},
    async submitForm() {
      this.submitLoading = true;
      let valid = await this.aysncValidateForm();
      if (valid == false) {
        this.submitLoading = false;
        return false;
      }
      this.changeTableData();
      //格式化数据
      let newObj = this.getFormData();
      
        //如果没有传入参数就是新增
        if (!this.keyValue) {

          request({
            url: baseUrl + "/"+this.addressUrl,
            method: "post",
            data : newObj
          }).then((res) => {
            this.submitLoading = false;
            this.$notify({
              title: "成功",
              message: "新增成功",
              type: "success",
            });
             this.$emit("onChange",true)
          });

        }
        else{

         request({
            url: baseUrl + "/"+this.addressUrl+"/" + this.keyValue,
            method: "put",
            data : newObj
          }).then((res) => {
            this.submitLoading = false;
            this.$notify({
              title: "成功",
              message: "修改成功",
              type: "success",
            });
             this.$emit("onChange",true)
          });

        }
       
       
      
    },
    cancelForm() {
      this.$emit("onChange", true)
    },
    formatTree(data, valueField, lableField, childField, type) {
      let tree = [];
      data.forEach((node, index) => {
        let newNode = {
          value: node[valueField],
          label: node[lableField],
        };
        if (type) {
          newNode.disabled = node[valueField] == undefined ? true : false
        }
        tree.push(newNode);
        if (node[childField] != null && node[childField].length > 0) {
          newNode.children = (this.formatTree(node[childField], valueField, lableField, childField,
          type));
        }
      }, this);
      return tree;
    },
    //辅助工作流 审批(编辑) 预留方法
    handleEdit() {
    },
    //子表单权限
    getAuthorityTableChildrenList(bindTable, children) {
      let column = [];
      if (bindTable && this.formEnCodeList && this.formEnCodeList[bindTable]) {
        let formSubEnCodeList = this.formEnCodeList[bindTable];
        if (children && children.length > 0) {
          column = children.map(ele2 => {
            if (formSubEnCodeList.includes(ele2.prop)) {
              ele2.hide = false;
            }
            else {
              ele2.hide = true;
            }
            if (ele2.hide == false) {
              //工作流中系统表单必填权限
              if (this.formSubTableNotRequiredList[bindTable] != undefined) {
                if (this.formSubTableNotRequiredList[bindTable].includes(ele2.prop)) {
                  ele2.required = false;
                }
                else {
                  ele2.required = true;
                }
              }
              ele2.rules = [];
              if (ele2.required) {
                ele2.rules = ele2.ruleList;
              }
              // disabled 属性
              if (this.formSubTableDisabledList[bindTable] != undefined) {
                if (this.formSubTableDisabledList[bindTable].includes(ele2.prop)) {
                  ele2.disabled = true;
                }
                else {
                  ele2.disabled = false;
                }
              }
            }
            return ele2;
          });
        }
        return column;
      }
      else {
        return children;
      }
    },
    getFormConfig() {
      let config = {
        "fields": [
          //排班申请
          {
          "__vModel__": "field1000e93",
          "__config__": {
            "label": "排班申请",
            "showLabel": false,
            "titleColor": null,
            "fontSize": null,
            "tag": "h2",
            "span": 24,
            "align": "top",
            "justify": "start",
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 100
          }
        },
        //部门id
        {
          "__vModel__": "F_DepartmentId",
          "__config__": {
            "label": "部门id",
            "showLabel": true,
            "tag": "el-select",
            "avueType": "select",
            "span": 24,
            "required": true,
            "saveField": "",
            "showField": "",
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 109,
            "fieldLength": "50",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_DepartmentId",
            "bindTableFieldType": "varchar"
          }
        },
        //部门名称
        {
          "__vModel__": "F_DepartmentName",
          "__type__": "info",
          "infoType": "department",
          "__organize__": true,
          "__config__": {
            "label": "所在部门",
            "showLabel": true,
            "tag": "avue-information-body",
            "avueType": "information-body",
            "defaultValue": "aebcb1b5e8f40ffc5f2b1bee84ffecd2",
            "required": false,
            "span": 24,
            "whetherToRebindSecondaryEditing": false,
            "bindTableField": "F_DepartmentName",
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 101,
            "placeholder": "当前部门",
            "fieldLength": "50",
            "bindTable": "oa_scheduling_approve",
            "bindTableFieldType": "varchar"
          }
        },
        //角色id
        {
          "__vModel__": "F_RoleId",
          "__config__": {
            "label": "角色id",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 113,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_RoleId",
            "bindTableFieldType": "varchar"
          }
        }, 
        //角色名称
        {
          "__vModel__": "F_RoleName",
          "__config__": {
            "label": "角色名称",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 114,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_RoleName",
            "bindTableFieldType": "varchar"
          }
        },
        //申请人id
        {
          "__vModel__": "F_UserId",
          "__config__": {
            "label": "申请人id",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 109,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_UserId",
            "bindTableFieldType": "varchar"
          }
        }, 
        //申请人姓名
        {
          "__vModel__": "F_UserName",
          "__config__": {
            "label": "申请人姓名",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 110,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_UserName",
            "bindTableFieldType": "varchar"
          }
        },
        //地区
        {
          "__vModel__": "F_Area",
          "__config__": {
            "label": "地区",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 115,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_Area",
            "bindTableFieldType": "varchar"
          }
        },
          //职级
        {
          "__vModel__": "F_Job",
          "__config__": {
            "label": "职级",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 136,
            "fieldLength": 500,
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_Job",
            "bindTableFieldType": "varchar"
          }
        }, 
        //考勤组id
        {
          "__vModel__": "F_AttendanceGroupId",
          "__config__": {
            "label": "考勤组id",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": true,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 102,
            "fieldLength": "50",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_AttendanceGroupId",
            "bindTableFieldType": "varchar"
          }
        }, 
        //考勤组名称
        {
          "__vModel__": "F_AttendanceGroupName",
          "__config__": {
            "label": "考勤组名称",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "required": true,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 103,
            "fieldLength": "50",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_AttendanceGroupName",
            "bindTableFieldType": "varchar"
          }
        }, 
        // 上传附件
        {
          "__vModel__": "F_FileUrl",
          "__config__": {
            "label": "上传附件",
            "tag": "el-upload",
            "avueType": "upload",
            "defaultValue": null,
            "showLabel": true,
            "required": true,
            "span": 24,
            "showTip": false,
            "buttonText": "点击上传",
            "fileSize": 2,
            "sizeUnit": "MB",
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 105,
            "fieldLength": "500",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_FileUrl",
            "bindTableFieldType": "varchar"
          }
        }, 
        //已生效
        {
          "__vModel__": "F_IsEffective",
          "__config__": {
            "label": "已生效",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "input-tip",
            "defaultValue": 0,
            "required": true,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 106,
            "fieldLength": "2",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_IsEffective",
            "bindTableFieldType": "int"
          }
        },
        //备注
        {
          "tempType": "textarea",
          "__vModel__": "F_Remark",
          "__config__": {
            "label": "备注",
            "showLabel": true,
            "tag": "el-input",
            "avueType": "textarea",
            "required": false,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 107,
            "fieldLength": "500",
            "bindTable": "oa_scheduling_approve",
            "bindTableField": "F_Remark",
            "bindTableFieldType": "varchar"
          }
        }, 
        //意见簿
        {
          "tempType": "textarea",
          "__vModel__": "field108895f",
          "__type__": "opinion",
          "__config__": {
            "label": "意见簿",
            "showLabel": true,
            "tag": "xjr-opinion-comonent",
            "defaultValue": null,
            "span": 24,
            "F_LgMarkCode": "",
            "prestrainField": "",
            "formId": 108
          }
        }]
      };
      return config;
    },

    getGroupByUserId(){
      let id
      if(this.formData.F_UserId){
        id = this.formData.F_UserId
      }else{
         id = this.$store.state.user.userInfo.F_UserId
      }
      getGroupByUserId(id).then(res => {
        if(res.data.success){
          this.formData['F_AttendanceGroupId'] = res.data.data.id
          this.formData['F_AttendanceGroupName'] = res.data.data.schedualGroupName
        }
      })
    },
    getUserInfo(){
      let params
      if(this.formData.F_UserId){
        params = {
          userId:this.formData.F_UserId
        }
      }else{
        params = {
          userId:this.$store.state.user.userInfo.F_UserId
        }
      }
      getUserDetailsById(params).then(res => {
        if(res && res.data && res.data.success){
          this.F_DepartmentData = res.data.data.F_Department
          this.F_RoleData = res.data.data.F_Role
          //赋值申请人信息
          this.formData['F_UserName'] =  res.data.data.F_RealName
          this.formData['F_UserId'] =  res.data.data.F_UserId
          this.formData['F_Area'] = res.data.data.F_Area
          this.formData['F_Job'] = res.data.data.F_Job
          this.initRoleData()
          this.initDepartmentData()
         }
      })
    },
    initDepartmentData(){
      if(this.F_DepartmentData && this.F_DepartmentData.length == 1){
        this.formData['F_DepartmentName'] = this.F_DepartmentData[0].F_FullName
        this.formData['F_DepartmentId'] = this.F_DepartmentData[0].F_DepartmentId
      }
    },
    initRoleData(){
      let roleId = []
      let roleName = []
      if(this.F_RoleData && this.F_RoleData.length > 0){
        this.F_RoleData.forEach(e => {
          roleId.push(e.F_RoleId)
          roleName.push(e.F_FullName)
        })
      }
      this.formData['F_RoleId'] = roleId.join(',')
      this.formData['F_RoleName'] = roleName.join(',')

    },
     Handleselect(){
      if(this.F_DepartmentData && this.F_DepartmentData.length > 0){
        this.F_DepartmentData.forEach(e => {
          if(e.F_DepartmentId == this.formData['F_DepartmentId']){
            this.formData['F_DepartmentName'] = e.F_ShortName
          }
        })
      }
    },
  }
}

</script>
<style>
.el-table__empty-block {
  width: 100% !important;
}

.avue-form__row {
  padding: 0 !important;
}

#editorphone {
  width: 375px;
  margin: 0 auto;
  border: 1px solid #E4E7ED;
  padding: 0 7.5px;
  background: #f5f6fa;
  height: 700px;
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: 5px;
}

#editorphone .el-col {
  border-bottom: 1px solid #F2F2F2;
  background: #fff;
  margin-bottom: 0;
  padding: 0 15px 6px !important;
  width: 100%;
}

#editorphone .el-form-item__label {
  line-height: 20px
}

#editorphone .el-input-group .el-input__inner {
  background: #f5f6fa
}

#editorphone .el-input__inner {
  border: 0
}

#editorphone .el-input-group__append,
#editorphone .el-input-group__prepend {
  border: 0;
  background: #edeef2;
  color: #666;
}

#editorphone .el-input-group .el-input__prefix {
  left: 44px
}

#editorphone .el-input-group .el-input__suffix {
  right: 44px
}

#editorphone .el-form-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-flow: wrap;
}

#editorphone .el-form-item__label {
  float: none;
  min-width: 85px;
  width: auto !important;
  text-align: left;
  flex: auto;
}

#editorphone .tinymce .el-form-item__label {
  min-width: 100%;
}

#editorphone .el-form-item__content {
  margin-left: 0px !important;
  flex: auto;
  width: calc(100% - 95px);
}

#editorphone .avueFormNoLable .el-form-item__label,
#editorphone .avueFormNoLable .avue-crud__pagination {
  display: none;
}

#editorphone .avueFormNoLable .el-collapse-item__wrap,
#editorphone .avueFormNoLable .el-collapse {
  border-bottom: 0
}

#editorphone .avueFormNoLable .el-col {
  border-bottom: 0;
  padding-bottom: 0
}

#editorphone .el-form-item__content .el-button:first-child {
  margin-left: 90px;
}

.el-upload__tip {
  line-height: 1.2;
}

</style>
